import nProgress from 'nprogress'
import router from './router'
import store from './store'

// 白名单
const whiteList = ['/login', '/404']

// 路由前置守卫
router.beforeEach((to, from, next) => {
  // 开启进度条
  nProgress.start()
  if (store.getters.token) {
    if (to.path === '/login') {
      next('/')
      // next()可以触发后置导航守卫， next('/xxx')不会触发后置导航守卫，需要手动关闭进度条
      nProgress.done()
    } else {
      next()
    }
  } else {
    // 没有token判断是否在白名单的页面，是就通过
    if (whiteList.includes(to.path)) {
      next()
    } else {
      // 不是，就让它跳到登录页面登录获取token
      next('/login')
      nProgress.done()
    }
  }
})

// 路由前置守卫
router.afterEach((to, from, next) => {
  // 关闭进度条
  nProgress.done()
})
